package org.hamcrest.collection; import static org.hamcrest.core.IsEqual.equalTo; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.List; import org.hamcrest.Description; import org.hamcrest.Factory; import org.hamcrest.Matcher; import org.hamcrest.TypeSafeMatcher; public class IsArrayContainingInOrder<E> extends TypeSafeMatcher<E[]> { private final Collection<Matcher<? super E>> matchers; private final IsIterableContainingInOrder<E> iterableMatcher; public IsArrayContainingInOrder(List<Matcher<? super E>> matchers) { this.iterableMatcher = new IsIterableContainingInOrder<E>(matchers); this.matchers = matchers; } @Override public boolean matchesSafely(E[] item) { return iterableMatcher.matches(Arrays.asList(item)); } @Override public void describeMismatchSafely(E[] item, Description mismatchDescription) { iterableMatcher.describeMismatch(Arrays.asList(item), mismatchDescription); }; public void describeTo(Description description) { description.appendList("[", ", ", "]", matchers); } @Factory public static <E> Matcher<E[]> arrayContaining(E... items) { List<Matcher<? super E>> matchers = new ArrayList<Matcher<? super E>>(); for (E item : items) { matchers.add(equalTo(item)); } return arrayContaining(matchers); } @Factory public static <E> Matcher<E[]> arrayContaining(Matcher<? super E>... matchers) { return arrayContaining(Arrays.asList(matchers)); } @Factory public static <E> Matcher<E[]> arrayContaining(List<Matcher<? super E>> matchers) { return new IsArrayContainingInOrder<E>(matchers); } }